/*
1 用户上滑页面 滚动条触底 开始加载下一页数据
    1 找到滚动条触底事件 微信小程序官方开发文档寻找
    2 判断还有没有下一页数据
        1 获取到总页数 只有总条数
          总页数 = Math.ceil(总条数 / 页容量 pagesize)
                = Math.ceil( 23 / 10)
        2 获取到当前的页码 pagenum
        3 判断一下 当前的页面是否大于等于 总页数
          表示 没有下一页数据
    
    3 假如没有下一页数据 弹出一个提示
    4 假如还有下一页数据 来加载下一页数据
      1 当前的页码 ++
      2 重新发送请求
      3 数据请求回来 要对data中的数组 进行 拼接 而不是全部替换!!!
2 下拉刷新页面
   1 触发下拉刷新事件 需要在页面的json文件开启一个配置项
     找到 触发下拉刷新的事件
   2 重置 数据 数组
   3 重置页码 设置为1
   4 重新发送请求
   5 数据请求回来 需要手动的关闭 等待效果
*/
import { request } from "../../request/index.js";
import regeneratorRuntime from '../../lib/runtime/runtime';
Page({
    /**
     * 页面的初始数据
     */
    data: {
        tabs: [{
                id: 0,
                value: "综合",
                isActive: true
            },
            {
                id: 1,
                value: "销量",
                isActive: false
            },
            {
                id: 2,
                value: "价格",
                isActive: false
            },
        ],
        goodsList: []
    },
    // 接口要的参数
    QueryParams: {
        query: "",
        cid: "",
        pagenum: 1,
        pagesize: 10
    },
    // 总页数
    totalPages: 1,
    /**
     * 生命周期函数--监听页面加载
     */
    onLoad: function(options) {
        this.QueryParams.cid = options.cid||"";
        this.QueryParams.query = options.query||"";
        this.getGoodsList();
    },

    // 获取商品列表数据
    async getGoodsList() {
        var res = await request({
            url: "/goods/search",
            data: this.QueryParams
        });
        // 获取 总条数
        const total = res.total;
        // 计算总页数
        this.totalPages = Math.ceil(total / this.QueryParams.pagesize);
        console.log(this.totalPages);
        this.setData({
            // 拼接了数组
            goodsList: [...this.data.goodsList, ...res.goods]
        })
        // 关闭下拉刷新的窗口
        wx.stopPullDownRefresh();
    },
    // 标题点击事件 从子组件传递过来
    handletabsItemTap(e) {
        // 1 获取被点击的标题索引
        const { index } = e.detail;
        // 2 修改源数组
        let { tabs } = this.data;
        tabs.forEach((v, i) => i === index ? v.isActive = true : v.isActive = false);
        // 3 赋值到data中
        this.setData({
            tabs
        })
    },
    // 页面上滑 滚动条触底事件
    onReachBottom() {
        // 1 判断还有没有下一页数据
        if (this.QueryParams.pagenum >= this.totalPages) {
            //没有下一页数据
            console.log('%c' + "没有下一页数据", "color:red;font-size:100px;background-image:linear-gradient(to right,#0094ff,pink");
            wx.showToast({
                title: '底部没内容了哦'
            });
        } else {
            //还有下一页数据
            console.log('%c' + "还有下一页数据", "color:red;font-size:100px;background-image:linear-gradient(to right,#0094ff,pink");
            this.QueryParams.pagenum++;
            this.getGoodsList();
        }
    },
    // 下拉刷新事件
    onPullDownRefresh() {
        // 1 重置数组
        this.setData({
                goodsList: []
            })
            // 2 重置页码
        this.QueryParams.pagenum = 1;
        // 3 发送请求
        this.getGoodsList();
    }
})